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(57) Abstract 

A global positioning 
system (GPS) receiver has 
fint circuitry for receiving 
and processing pseudorandom 
sequences transmitted by a 
number of GPS satellites. The 
first circuitry is configured 
to perfoim conventional 
correlation operations on 
the received pseudorandom 
sequences to deteimioe 
pseudoranges from the GPS 
receiver to the GPS satellites. 
The GPS receiver also includes 
second circuitry coupled to 
the first circuitry. The second 
circuitry is configured to receive 
and process the pseudorandom 
sequences during bloclcage 
conditions. The second circuitry 
processes ttw pseudorandom 
sequences by digitizing and 
storing a predetermined record 
length of the received sequences 
and then performing fast 

convolution operations on the stored data to dctemiine the pseudoranges. The GPS receiver may have » ^^^^^^ ^ 




GPS signals from in view satclUtcs and downconvcrting the RF frequency of the received GPS signals to an intCTnediate frequciicy 
(IF) The IF signals are split into two signal paths, a first of which provides the conventional correlation processing to <^cui**3 
pseudoranges. During bloclcage conditions, the IF signal is passed to the second signal path wherein the IF signals arc <ii8«iied «ndstorea 



in memory and later processed using the fast convolution operations to provide the pseudoranges. Alternative arrangcrrients 
siznal patiis include separate downconvertcis or shared digitizers. One cmbodiroem provides both signal paths on a smgle l"^^^ 
with shared circuitry executing computer-readable instnicdons to perform GPS signal processing appropriate.to the reception condiuons. 
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A GPS RECEIVER AND METHOD FOR PROCESSING GPS SIGNALS 
RELATED APPLICATIQNS 

This application is related to and hereby claims the benefit of the filing date 
of a provisional patent application by the same inventor, Nornian F. Krasner, 
which application is entided Low Power, Sensitive Pseudorange Measurement 
Apparatus and Method for Global Posidoning Satellites Systems, Serial No. 
60/005,318, filed October 9. 1995. 

FrRIPOFTPrFTNVF,NnON 

The present invention concerns receivers capable of determining 
pseudoranges to orbiting satellites and, in particular, concerns such receivers as 
find application in global positioning satellite systems (GPS). 

BACKGROUND 

GPS receivers noranally determine their position by computing relative 
times of arrival of signals transmitted simultaneously from a multiplicity of GPS 
(or NA VSTAR) satellites. These satellites transmit, as pan of dieir message, both 
satellite positioning data as well as data on clock timing, so-called "ephemcris" 
data. The process of searching for and acquiring GPS signals, reading the 
ephemeris data for a multiplicity of satellites and computing the location of the 
receiver from this data is time consuming, often requiring several minutes. In 
many cases, this lengthy processing time is unacceptable and, furthermore, gready 
limits battery life in micro-miniaturized portable applications. 

Anodier limitation of current GPS receivers is that their operation is limited 
to situations in which multiple satellites are cleariy in view, without obstructions, 
and where a good quality antenna is properly positioned to receive such signals. 
As such, they normally are iinusable in portable, body mounted applications; in 
areas where there is significant foliage or building blockage (e.g., urban canyons); 
and in in-building applications. 

There are two principal functions of GPS receiving systems: (1 ) 
computation of the pseudoranges to the various GPS satellites, and (2) 
computation of the position of the receiving platform using these pseudoranges 
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and satellite timing and cphemcris data. The pscudoranges are simply the dme 
delays measured between the received signal from each satellite and a local clock. 
The satellite ephemeris and timing data is extracted from the GPS signal once it is 
acquired and tracked As stated above, collecting this infomiadon noraially takes a 
relatively long time (30 seconds to several minutes) and must be accomplished 
with a good received signal level in order to achieve low error rates. 

Virtually all known GPS receivers utilize correlation methods to compute 
pscudoranges. GPS signals contain high rate repetitive signals called 
pseudorandom (PN) sequences. The codes available for civilian applicarions arc 
called C/A codes and have a binary phase-reversal rate, or '^chipping" rate, of 
1.023 MHz and a repetition period of 1023 chips for a code pehod of 1 msec. The 
code sequences belong to a family known as Gold codes. Each GPS satellite 
broadcasts a signal with a unique Gold code. 

For a signal received from a given GPS satellite, following a 
downconvcrsion pnxcss to baseband, a correlation receiver multiplies the received 
signal by a stored replica of the appropriate Gold code contained within its local 
memory, and then integrates, or lowpass filters, the product in order to obtain an 
indication of the presence of the signal. This process is termed a "correlation" 
operation. By sequentially adjusting the relative timing of diis stored replica 
relative to the received signal, and observing the correlation output, the receiver 
can determine the time delay between the received signal and a local clock. The 
initial determination of the presence of such an output is tcmied "acquisition." 
Once acquisition occurs, the process enten the "tracking" phase in which the 
timing of the local reference is adjusted in small amounts in order to maintain a 
high correlation output The correlation output during the tracking phase may be 
viewed as the GPS signal widi the pseudorandom code removed, or. in common 
terminology, "despread." This signal is narrow band, with bandwidth 
commensurate with a 50 bit per second binary phase shift keyed data signal which 
is superimposed on the GPS waveform. 

The correlation acquisition process is very time consuming, especially if 
received signals arc weak. To improve acquisition time, most GPS receivers 
utilize a multiplicity of correlators (up to 12 typically) which allows a parallel 
search for correlation peaks. 
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Somc prior GPS receivers have used FFT techniques to determine the 
Dopplcr frequency of the received GPS signal. These receivers utilize 
conventional correlation opcradons to dcspread the GPS signal and provide a 
narrow band signal with bandwidth typically in the range of 10 kHz to 30 kHz. 
The resulting narrow band signal is then Fourier analyzed using FFT algorithms to 
determine the carrier frequency. The determinadon of such a carrier 
simultaneously provides an indication that the local FN reference is adjusted to the 
conect phase of die received signal and provides an accurate measurement of 
carrier frequency. This frequency may then be utilized in the tracking operation of 
the TBceivcrs, 

U.S. Patent No. 5,420,592 to Johnson discusses the use of FFT 
algorithms to compute pseudoranges at a central processing location rather than at 
a mobile unit According to that method, a snapshot of data is collected by a GPS 
receiver and then transmitted over a data link to a remote receiver where it 
undergoes FFT processing. However, the method disclosed therein computes 
only a single forward and inverse Fast Fourier Transform (corresponding to four 
PN periods) to perform the set of correlations. 

SUMMARY 

One embodiment of the present invention provides a global positioning 
system (GPS) receiver having first circuitry for receiving and processing 
pseudorandom sequences n-ansmitted by a number of GPS satellites. The first 
circuitry is configured to perform conventional correlation operations on the 
received pseudorandom sequences to determine pseudoranges from the GPS 
receiver to the GPS satellites. The GPS receiver also includes second circuitry 
coupled to the fint circuitry. The second ciicuitty is configured to receive and 
process the pseudorandom sequences during blockage conditions. The second 
circuitry processes the pseudorandom sequences by digitizing and storing a 
predetermined record length of die received sequences and then performs fast 
convolution operations on the stored data to determine the pseudoranges. 

In one embodiment, the GPS receiver has a common antenna for receiving 
GPS signals from in view satellites; and a common downconvencr for reducing 
the RF frequency of the received GPS signals to an inieimediaie frequency (IF). 
The IF signals are then split into two sigrul paths. A first of the signal paths 



Printed from Mimosa page -5- 



wo 97/14057 PCTAJS96/16178 



provides for conventional GPS signal processing using correlation operations to 
calculate the pseudoranges. During blockage conditions, the IF signal is passed to 
the second signal path wherein the IF signals are digitized and stored in nnemoiy 
for later processing in the receiver. This later processing is accomplished using a 
programmable digital signal processor which executes the instructions necessary to 
perform fast convolution operations on the sanqiled IF GPS signals to provide the 
pseudoranges. 

In yet another embodiment of the present invention, the GPS receiver has a 
common antenna for receiving GPS signals firom in view satellites and a switch for 
choosing between two signal paths. A first of the signal paths provides for 
conventional GPS signal processing, wherein pseudoranges are calculated using 
correlation operations. During blockage conditions, a second signal path is used 
wherein the signals are digitized and stored in memory for later processing. This 
later processing is accomplished using fast convolution operations on the sampled 
GPS signals to provide the pseudoranges. 

A further embodiment of the present invention provides a GPS receiver 
with a common antenna for receiving GPS signals from in view satellites and a 
common downconvener and digitizer. Sampled GPS signals received from the in 
view satellites are provided to a first signal path for conventional conelation 
processing to determine pseudoranges. During blockage conditions, the sampled 
GPS signals are provided to a second signal path for processing using fast 
convolution opmtipns to determine the pseudoranges. The two signal paths may 
be provided by separate circuitry by conunon circuitry executing computer 
readable instructions appropriate for the given reception conditions. 

An additional embodiment of the present invention provides a method for 
determining the position of a remote GPS receiver by storing GPS satellite 
information, including Doppler, in the remote unit During blockage conditions, 
the remote unit uses this information and sampled GPS signals from in view 
satellites to subsequendy cornpute pseudoranges to the satellites using fast 
convolution operations. The computed pseudoranges may then used to determine 
the position of the remote utut. The position determination can occur at the remote 
unit or at a basestation. Where the position determination is performed at a 
basestation, the remote unit transnuts the pseudoranges to the basestation via a data 
link. 
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BMEF DESCRIPTION QF THE PRAVVTNQS 

The present invention is illustzatcd by way of example and not limitation in 
the figures of the accompanying drawings in which like references indicate similar 
elements and in which: 

Figures 1 A - ID are block diagrams of the major components of a remote 
GPS receiving system utilizing the apparatus and methods of the present invendon; 

Figure 2 is a block diagram of an exemplary embodiment of the dual mode 
GPS receiving system corresponding to Rgurc IC and utilizing the apparatus and 
methods of the present invendon; 

Figures 3 A and 3B provide two alternatives for the RF and DF portions of 
the dual mode GPS receiver illustrated in Figure 2; 

Figure 4 shows a flowgraph of the major software operations performed 
by a programmable DSP processor as illustrated in Figure 2 in accordance with the 
present invention; and 

Figures 5A - 5£ illustrate signal processing waveforms at various stages of 
processing in a dual nxxle GPS receiver according to the present invention. 

DETAILED D ESCRIPTION 

This invention concerns apparatus and methods for computing the position 
of a mobile, or remote, global positioning system (GPS) receiver with very low 
received signal levels. As iUustrated in Rgures lA - ID, a GPS receiver 10 has 
first circuitry for receiving and processing pseudorandom sequences transmitted 
by a number of GPS satellites. The first circuitry is configured to perform 
conventional correlation operations on the received pseudorandom sequences to 
determinie pseudoranges from the GPS receiver to the GPS satellites. 
Accordingly, the first circuitry is referred to herein as a conventional GPS receiver 
12. The GPS receiver 10 also includes second circuitry coupled to the 
conventional GPS receiver 12. The second circuitry is configured to receive and 
process the pseudorandom sequences during blockage conditions. Blockage 
conditions are those conditions where the conventional GPS receiver 12 may have 
difficulty acquiring and/or tracking GPS signals from GPS satellites, such as 
occasions where the GPS signals have very low signal to noise ratios* urban 
canyon conditions where GPS signals are blocked due to tall buildings, tunnels 
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and other obstacles, conditions where the GPS receiver 10 is being operated under 
cover of trees or other foliage, in btiilding applications where GPS receiver 10 is 
being operated indoors, and other blockage conditions as will be appreciated by 
those skilled in the ait. 

The second circuitry is referred to herein as a snapshot GPS receiver 14 
which processes the pseudorandom sequences by digitizing and storing GPS data 
made up of a predetermined record length of the received pseudorandom 
sequences. Once the GPS data has been stored, snapshot GPS receiver 14 
performs fast convolution operations on the stored data to determine the 
pseudoranges. The maiuier in which these computations are performed are 
discussed in detail below. 

As illustrated in Figures lA - ID, GPS receiver 10 includes two signal 
paths, corresponding to conventional GPS receiver 12 aiKl snapshot GPS receiver 
14, Various embodiments may include common cireuitry within these signal paths 
for receiving GPS signals from in view satellites, downconverting the RF 
frequency of the received GPS signals to an intermediate frequency (IF) and/or 
digitizing the received GPS signals. For example, all the embodiments illustrated 
in Figures lA - ID include a common antenna 16 for receiving GPS signals. 
However, separate antennas for conventional GPS receiver 12 and snq)shot GPS 
receiver 14 could be used. The embodiment illustrated in Figure IB provides a 
common antenna switch 18 for choosing between the two signal paths. During 
non-blockage reception conditions, switch 18 will allow received GPS signals to 
pass from antenna 16 to conventional GPS receiver 12. Then, during blockage 
conditions, switch 1 8 will be configured to allow GPS signals to pass from 
antenna 16 to snapshot GPS receiver 14. As shown in Figure lA, however, 
switch 18 may be omitted and signals from antenna 16 may be provided 
simultaneously to both conventional GPS receiver 12 and snapshot GPS receiver 
14. For such an embodiment, conventional GPS receiver 12 and snapshot GPS 
receiver 14 will communicate with one another (for example, through the use of a 
common processor or by passing control information between separate 
processors) to determine which component will provide paeudorange computation. 

An alternative embodiment, shown in Figure IC, provides a common RF 
to IF downconvcrter 20 fcH" both signal paths. This embodiment allows for 
reduced complexity in conventional GPS receiver 12 and snapshot GPS receiver 
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1 4. The use of shared ciicuitiy of this type also achieves a space savings for the 
overaU GPS receiver 10. It should be appreciated that although the embodiment of 
Figure IC includes switch 18, the shared RF to IF convener 20 could also be used 
in the embodiment illustrated in Figure 1 A. , 

Yet another embodiment of GPS receiver 10 is Ulusirated in Figure ID. in 
this embodiment, the shared circuitry includes RF to.IF converter 20 and digitizer 
22. It will be appreciated that for this embodiment, conventional GPS receiver 12 
is configured as a digital receiver, that is, a receiver which computed pscudoranges 
using digital logic in the form of hardware correlators or a programmable signal 
processor executing appropriate instructions. Both types of conventional GPS 
receivers are known in the GPS art Further review of the detailed discussion of 
the signal processing functions performed by snapshot GPS receiver 14 provided 
below will demonstrate how such an embodiment can be implemented in 
accordance with the present invention. 

The embodiment of Figure ID may have conventional GPS receiver 12 and 
snapshot GPS receiver 14 as separate functional units (e.g.. separate integrated 
circuits) configured to communicate with one another. Alternatively, these two 
units may be formed on a single integrated circuit 30 with shared circuitry 
configured to perform GPS signal processing appropriate to the reception 
conditions. That is, for non-blockage conditions, the circuitry may be configured 
to perform conventional GPS signal processing as described above. Then, when 
blockage conditions are encountered, the circuitry could be configured to perform 
snapshot GPS signal processing as will be described in detail below. Those 
skilled in the art will apprcdaie that these functions could be accomplished with a 
programmable digital signal processor and appropriate computer readable 
instructions provided in, for example, a programmable read only memory (PROM) 
or with specially designed hardware circuitry. In either case, RF to IF 
downconverter 20 and digitizer 22 may be included on the single integrated circuit 
30, However, because such contponents are commercially available in their 
separate form today, a presently prefer r e d embodiment of the Figure ID 
in^lementarion uses independent RF to IF downconverter 20 and digitizer 22 as 

illustrated. . . . . . ^ . 

Those skilled in the art will appreciate that Figures 1 A - ID merely 
illustrate four of many potential embodiments of the present invention. Variations 



Printed from Mimosa page -9- 



wo 97/14057 



PCT/US96/i6178 



-8- 

of these embodiments are possible wherein various circuiuy or functions are 
shared between conventional GPS receiver 12 and snapshot GPS receiver 14. 
These variations are within the spirit and scope of the present invention. For 
convenience, the embodiment of Figure IC will be chosen for further detailed 
description below because it illustrates an embodiment with an inteimediate level 
of shared circuitry which may be commercially available. It should further be 
noted diat pseudoranges may be used to compute the geographical position of GPS 
receiver 10 in many different ways. Three examples are: 

Method 1 : By retransmitting the Satellite Data Messages to 
the GPS receiver 10 from a basestarion 50, GPS 
receiver 10 may combine this information with the 
pseudorange measurements to compute its position. 
See, for example, U.S. Patent No. 5,365,450, 
which is incorporated herein by reference. 
Method 2: GPS receiver 10 may gather the satellite 

ephemeris data from the reception of GPS signals in 
the normal manner that is conunonly practiced in the 
an using conventional GPS receiver 12. This data, 
which typically is valid for one to two hours, may 
be combined with pseudorange measurements from 
conventional GPS receiver 12 or, during blockage 
conditions, from snapshot GPS receiver 14 to 
ccHnplete die position calculation. 
Method 3: GPS receiver 10 may transmit over a 

communications link 52 the pseudoranges computed 
by conventional GPS receiver 12 or snapshot GPS 
receiver 14 to bascstadon 50 which can combine 
this information with the satellite ephemeris data to 
complete the position calculation. See, for example, 
U.S. Patent No. 5,225,842, which is incorporated 
herein by reference. 
Method 2 provides the advantage of allowing GPS receiver 10 to operate in 
a self-contained maimer. That is, no external communications are required. In 
Methods 1 and 3, basestation 50 requires information regarding the satellites in 
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vicw of GPS receiver 10. This may be accomplished by knowing approximately 
the area in which GPS receiver 10 is operating or by ensuring that basestation 50 
and GPS receiver 10 have a common view of ail satellites of interest and arc 
positioned close enough to one another to resolve a time ambiguity associated with 
the repetition rate of the GPS pseudorandom codes. This latter condition will be 
met for a range between basestation 50 and GPS receiver 10 of 1/2 times the speed 
of light times the PN repetition period (1 millisecond), or about 150 km. 

Referring now to Figure 2, one embodiment of GPS receiver 10 (that 
corresponding to the embodiment illustrated in Figure IC) is shown. Ahhough the 
remaining discussion will be directed piimaiily to the embodiment illustrated in 
Figure 2, it will be apparent to those skilled in the an that the apparatus and 
methods^ including the signal processing functions to be described, may be used 
in any ot all of the embodiments illustrated in Figures 1 A - ID. For those 
embodiments, such as the Figure ID embodiment, where different circuitry is 
shared between conventional GPS receiver 12 and snapshot GPS receiver 14, 
appropriate signal paths would be provided. 

Upon power up and initialization, switch 18 is configured to provide a 
signal path from RF to IF downconvciter 20 to conventional GPS receiver 12. 
Conventional GPS receiver 12 begins to compute pseudoranges using 
conventional correlation operations as described above. Conventional GPS 
receiver 12 also receives, decodes and stores satellite cphemeris data received from 
the in view GPS satellites. In addition, conventional GPS receiver 80 stores 
Doppler information associated with each of the in view GPS satellites. This 
Doppler infcxmation will typically be in the fonn of frequency infomiation and can 
be digitized and stored in RAM 32 under the control of microprocessor 34. The 
Ekyppler information will be used by GPS receiver 10 when blockage conditions 
are encountered as described below. Where available, conventional GPS receiver 
12 may use differential GPS OOGPS) correction information transmitted from 
basestation 50 to assist in detemnining the position of the GPS receiver 10. The 
position so determined may be displayed on display 36 as latitude and longitude 
information, a highlighted map display or another position indication. 

Alternatively, for an embodiment which utilizes the Method 3 approach as 
described above, the pseudorange information computed by conventional GPS 
receiver 12 can be transmitted to basestation 50 via modem 38 and communication 
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antenna 40 for final position determination. In such an embodiment, the 
pseudorange inforaiation would be transmitted over a communicadon link 42 from 
the GPS receiver 10 to the basestadon 50. Basestadon SO would be configured 
with its own GPS receiver, thereby providing a means of obtaining satellite 
ephemeris informadon. A processor located at basestadon 50 would be provided 
with infonnadon regarding the approximate position of GPS receiver 10 (so that 
the proper satellite infonnadon could be selected) and would combine the 
ephemeris infonnadon with the received pseudoranges to compute the posidon of 
the GPS receiver 10. This computed posidon infonnadon could then be 
transmitted back to GPS receiver 10 via communication link 42 where it would be 
displayed on display 36. 

Under either method, GPS receiver 10 would display the results of a 
position computation upon receipt of a fix command, i.e., a command to determine 
the geographic location of GPS receiver 10. The fix command may be provided 
via a user using front panel controls 44 (or from the basestadon 50 when the 
optional modem 58 and associated communication antenna 40 are used). Upon 
receipt of die fix command, microprocessor 34 polls conventional GPS receiver 12 
for a position report and conventional GPS receiver 12 demodulates the received 
GPS signals and produces pseudwange infoimation in the conventional fashion as 
described above. 

Under normal operating conditions, Le., when antenna 16 has a clear view 
of the sky, conventional GPS receiver 12 is able to accurately acquire and track a 
sufficient number of GPS satellites to produce pseudorange and/or posidon 
infonnadon for GPS receiver 10. However, such conditions may rapidly 
deteriorate when, for example, GPS receiver 10 is moved into an urban or other 
canyon, inside a building, under a tree or other foliage, or into some other area 
which results in at least a partial blockage of the sky. Under these conditions, it is 
likely diat conventional GPS receiver 12 will be unable to urack a sufficient number 
of satellites to produce reliable pseudorange and/or position infonnation. The 
blockage conditions will result in a reduced signal to noise ratio for the GPS 
signals received by conventional GPS receiver 12 and diese reduced signal to 
noise levels can be used as a trigger for GPS receiver 10 to switch to a "snapshot" 
mode. 
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Upon detecting the reduced signal to noise levels of received GPS signals, 
or under user command entered through front panel controls 44, conventional 
GPS receiver 12 signals microprocessor 34 that it is encountering a blockage 
condition. Upon receipt of such a signal, microprocessor 34 configures GPS 
icccivcr 10 to operate in the snq)shot mode. When the GPS receiver 10 enters the 
snapshot mode, microprocessor 34 activates switch 1 8 so as to provide a signal 
path to the circuitry which makes up snapshot GPS receiver 14. This circuitry 
includes analog to digital converter (A/D) 46, digital snapshot memoty 48, general 
purpose programmable digital signal processor (DSP) 52, pn)gram EPROM 54, 
field programmable gate array (FPGA) 56. frequency synthesizer 58 (which is 
also used in conjunction with conventional GPS receiver 12 to provide a local 
oscillator for RF to IF downconvcrter 20), battery and power control circuit 60 
and microprocessor 34 (which may also control the operations of conventional 
GPS receiver 12). 

While in snapshot mode, when GPS receiver 10 receives a fix command, 
micrt^jTocessor 34 activates A/D converter 46 and digital snapshot memory 48 via 
the battery and power control circuit 60. This causes signals from the GPS 
satellites^ which are received via antenna 16 and do wncon verted to an IF 
frequency in RF to IF downconvcrter 20, to undergo digitization. That is, the IF 
signals are sampled by A/D converter 46 at a frequency equal to the sample clock 
generated by frequency synthesizer 58 and the resulting data is stored in digital 
snapshot memory 48. A contiguous set of such data, typically corresponds to a 
d\iration of 100 milliseconds to 1 second (or even longer). The addressing of 
digital snapshot memory 48 is controlled by FPGA 56. 

Note that all this time (while the snapshot memory 48 is being filled with 
the digitized GPS signals from the in view sateUites) the DSP 52 may be in a low 
power state, >K/D converter 46 need only be turned on for a shon period of time, 
sufficient to collect and store the data required for pseudorange calculation. After 
the data collection is complete, these converter circuits may be turned off, thus not 
contributing to additional power dissipation during the actual pseudorange 
calculation. The pseudorange calculation is then pcrfomied using, in one 
cmbodinoent, a general purpose, programmable digital signal prcx:essing integrated 
circuit (DSP 52), as exemplified by a TMS320C30 integrated circuit from Texas 
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Instiuments. DSP 52 is placed in an active power state by the microprocessor 34 
via the battery and power control circuit 60 prior to performing such calculations. 

This DSP S2 differs from others used in some GPS units in that it is 
general purpose and programmable, as con^aied to specialized custom digital 
signal processing integrated circuits. Furthermore, the DSP 32 makes possible the 
use of fast convolution algorithms, which pemut very rapid computation of the 
pseudoranges by performing rapidly a large number of convolution operations 
between a locally generated reference and the received GPS signals. Typically, 
2046 such operarions are required to complete the search for the epochs of each 
received GPS signal The fast convolution algorithms permit a simultaneous and 
parallel search of all such positions, thus speeding the required computation 
process by a factor of 10 to 100 over conventional approaches. 

Once the DSP 52 has computed the pseudoranges (in the fashion described 
in detail below), this information may be used to compute the position of GPS 
receiver 10 using the satellite ephemcris data previously stored by conventional 
GPS receiver 12. The manner in which such position computations are performed 
are well known in the art and the resulting position information may be displayed 
on display 36 as latitude and longitude (and altitude) information, as a highlighted 
map position or in another useful fashion. The position computations may be 
performed by microprocessor 34 executing program commands stored in 
EEPROM 62 OT by DSP 52 executing commands stored in Program EPROM 54. 
The positicMi computations may be made more accurately using DGPS corrections 
received from basestation 50 or other source of DGPS information (e.g., FM 
subcarrier broadcasts). 

Alternatively, for a Method 3-type embodiment, once the DSP 52 
completes its computation of pseudoranges for each of the in view satellites, it may 
transmit this information to basestation 50 across communication link 42 via 
modem 38 and under the control of microprocessor 34. At this time the 
microprocessor 34 may cause the DSP 52 to again enter a low power state by 
sending an appropriate control signal to the banery and power control circuit 60. 
In addition to the pseudorange data, a time tag may be simultaneously transnutted 
to basestation SO. The time tag indicates the elapsed time firom the initial data 
collection in the digital snapshot memory 48 to the time of transmission of the d^^ 
over the communication link 42. This time tag improves the capability of the 
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basestadon 50 to complete the position calculation because it allows the 
computation of the GPS satellites respective positions at the time of data collection. 

Modem 38, in one embodiment, utilizes a separate communication antenna 
40 to transmit and receive messages over communication link 42. It will be 
appreciated that modem 38 includes a communications receiver and a 
communications transmitter which are alternatively coupled to antenna 42 as 
required. Similarly, basestation 50 may use a separate antenna 64 to transmit and 
receive communication link messages, thus allowing continuous reception of GPS 
signals xda GPS antenna 66 at the basestation 50. 

As indicated above, the digital snapshot memory 48 captures a record 
length of data corresponding to a relatively long period of time. The efficient 
processing of this large block of data using fast convolution methods contributes 
to the ability of the present invention to process signals at low received levels 
(e.g., when reception is poor due to partial blockage firom buildings, trees, etc.). 
All pseudoranges for visible GPS satellites are computed using diis same buffered 
data. This provides improved performance relative to continuous tracking (Le., 
conventional) GPS receivers in situations (such as urban blockage conditions) in 
which the signal amplitude is rapidly changing. 

Where a communication link 42 is used, GPS receiver 10 may employ an 
automatic frequency control (AFC) loop to lock to this carrier and thereby further 
calibrate its own reference oscillator. A message transmission time of 10 msec, 
with a received signal to noise ratio of 20 dB, will normally allow frequency 
measurement via an AFC to an accuracy of 10 Hz or better. This will typically be 
more than adequate for the requirements of the present invention. 

In one embodiment, the communication link 42 may be a commercially 
available narrow bandwidth radio frequency communications medium, such as a 
two-way pager system. This system may be used in embodiments where the 
amount of data to be transinitted between the basestation 50 and the GPS receiver 
10 is relatively soiall (e.g., where basesution 50 sends a command to GPS 
receiver 10 to perform a position fix). In other embodiments, where the amount of 
data to be transferred between basestation 50 and GPS receiver 10 is relatively 
large, a higher bandwidth communication link 42 will be required. 

A representative example of an RF to IF downconvcrtcr 20 and digitizing 
system for the CPS receiver 10 is shown in Figure 3 A (note that switch 18 has not 
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bccn shown for sake of clarity). The input signal from antenna 16 at 1575.42 
MHz is passed through a bandlimiting filter (BPF) 70 and low noise amplifier 
(LNA) 72 and sent to a finequcncy conversion stage. The local oscillator (LO) 76 
used in this stage is phase locked (via PLL 78) to a 2.048 MHz (or harmonic 
thereof) temperature compensated crystal oscillator (TCXO) 80. In a preferred 
in^lcmentadon, the LO frequency would be 1531.392 MHz, which is 2991 x 
0.512 MHz. The resulting IF signal is then centered at 44.028 MHz. This IF is 
desirable due to the availability of low cost components near 44 MHz. In 
particular, surface acoustic wave filters (SAW), which are utilized in abundance in 
television applications, are readily available. Of course, other bandlimiting devices 
could be used instead of SAW devices. 

The received GPS signal is mixed witii the LO signal in mixer 74 to 
produce the EF signal. This IF signal is passed through a SAW filter 84, for 
precision bandlimiting to 2 MHz bandwidth, and then sent xoml/Q down- 
converter 88, which translates the signal to near baseband (4 kHz center frequency 
nominally). The local oscillator frequency for this downconvcrtcr 88 is derived 
from the 2.048 MHz TCKO 80 as die 43rd harmonic of 1.024 MHz, that is 
44.032 MHz. 

The VQ downconverter 88 is generally commercially available as an RF 
component. It typically consists of two mixers and lowpass filters. In such 
instances, the input ports of one mixer are fed with the IF signal and the LO signal 
and the input ports to the other mixer are fed with the same IF signal and the LO 
signal phase shifted by 90**. The outputs of die two mixers are lowpass filtered to 
remove feedthrough and other distortion products. 

As shown in Figure 3A, amplifiers 82 and 86 may be used before and after 
the bandlimiting operation as required. 

The two outputs of the VQ downconverter 88 are sent to two matched A/D 
converters 46 which san^le the signals at 2.048 MHz. An alternative 
inq)lementation replaces the A/D converters 46 with comparators (not shown), 
each of which outputs a two-valued (one-bit) sequence of data in accordance with 
the polarity of the incoming signal. It is well known that this approach results in a 
loss of approximately 1.96 dB in receiver sensitivity relative to a multOevel A/D 
converter. However, there may be substantial cost sayings in use of a comparator 
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vs. A/D conveners, as well as in the reduced memory requirement in the following 
digital snapshot mcnxTry 48. 

An alternative implementation of the RF to IF downconvcncr and digitizing 
system is shown in Figure 3B which utilizes a bandpass samphng method (again, 
switch 18 has not been shown). The TCXO 80 employed is at frequency 4.096 
MHz (or an harmonic thereof). The TCXO 80 output may be used as the sample 
clock to the A/D convener 46 (or comparator); this acts to translate the signal to 
1.028 MHz. This frequency is the difference between the 11 th harmonic of 4.096 
MHz and the input IF frequency 44.028 MHz. The resulting 1 .028 MHz IF is 
nearly one-fourth the sample rate, which is known to be nearly ideal in minimizing 
sampling type distortions. As compared to the VQ sampling of Figure 3A, this 
single sampler provides one channel of data rather than two. but at twice the rate. 
In addition, die data is effectively at an EF of 1.028 MHz. I/Q frequency 
conversion to near 0 MHz would then be implemented by digital means in the 
following processing to be described. The apparatus of Figures 3A and 3B arc 
competitive in cost and complexity; often component availability dictates the 
preferred approach. It will be apparent to those skilled in the art, however, that 
other receiver configurations could be used to achieve similar results. 

In order to simplify the following discussion, the following assumes that 
the VQ sampling of Figure 3 A is employed and that the digital snapshot memory 
48 contains two channels of digitized data at 2.048 MHz. 

Details of the signal processing performed in the DSP 52 may be 
understood with the aid of the flowgraph of Figure 4 and the pictorial of Figures 
S A - SE. It will be apparent to those skilled in the an that the machine code, or 
other suitable code, for performing the signal processing to be described may be 
stored in EPROM 54. Other non-volatile storage devices could also be used. The 
objective of the processing is to determine the timing of the received waveform 
with respect to a locally generated waveform. Funhermore, in order to achieve 
high sensitivity, a very long portion of such a wavefomi, typically 100 
milliseconds to 1 second, is processed^ 

In order to understand the processing, one first notes that each received 
GPS signal (C/A nxxle) is consmicted from a high rate (1 MHz) repetitive 
pseudorandom (PN) pattern of 1023 symbols, commonly called "chips." These 
"chips'* resemble the wavefomi shown in Figure 5 A. Further imposed on this 
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pattem is low rate data* transmitted from the satellite at 50 baud All of this data is 
received at a very low signai-to-noisc ratio as measured in a 2 MHz bandwidth. If 
the carrier frequency and all data rates were known to great precision, and no data 
were present, then the signal-to-noisc rado could be greatly improved, and the data 
greatly reduced, by adding to one another successive frames. For example, there 
are 1000 PN firames over a period of 1 second. The first such frame could be 
coherendy added to the next frame, the result added to the third frame, etc. The 
result would be a signal having a duration of 1023 chips. The phasing of this 
sequence could then be compared to a local reference sequence to determine the 
relative timing between the two. thus establishing the so-called pseudorange. 

The above process must be carried out separately for each satellite in view 
from the same set of stored received data in the digital snapshot memory 48, since, 
in general, the GPS signals from different satellites have different Dopplcr 
frequencies and the PN patterns differ from one another. 

The above process is made difficult by the faa that the carrier frequency 
may be unknown by in excess of 5 kHz due to signal Doppler uncertainty and by 
an addidonal amount due to receiver local oscillator uncertainty. These Doppler 
uncertainties arc removed in one embodiment of the present invention by storing 
such inforanation in RAM 32 as described above. Alternatively, Dopplcr 
information could be transmitted from basestation 50, which simultaneously 
monitors all GPS signals from in view satellites, in response to a signal via 
communication link 42 indicating that GPS receiver 10 had entered the snapshot 
HKxle. Thus, Doppler search is avoided at the GPS receiver 10. The local 
oscillator uncertainty can also be gready reduced (to perhaps 50 Hz) by the 
aforementioned AFC operation performed using the communication link 42 signal. 

The presence of 50 baud data superimposed on the GPS signal still liaiits 
the coherent summation of PN frames beyond a period of 20 msec. That is, at 
most 20 frames may be coherendy added before data sign inversions prevent 
further processing gain. Additional processing gain may be achieved through 
matched filtering and summation of the magnitudes (or squares of magrutudcs) of 
the frames, as detailed in the following paragraphs. 

The flowgraph of Figure 4 begins at step 100 with a command to initialize 
a snapshot GPS processing operation (termed a "Fix Command" in Fig, 4). 
Where necessary (e.g., where no prior Doppler information has been stored by 
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convcntional GPS receiver 12), the conunand ihcliides a transmission from GPS 
receiver 10 to basestation 50 for Doppler information for the in view satellites to be 
transmitted from basestation SO over communication link 42. At step 102, the 
GPS receiver 10 computes its local oscillator drift, for example, by frequency 
locking to the signal transmitted from the basestation SO. An altemadve would be 
to utilize a very good quality temperature compensated crystal oscillator (TCXO 
80) in the unit. For example, digitally controlled TCXOs, so-called DCXOs, 
currently can achieve accuracy of about 0.1 parts per million, or an ciior of about 
150 Hz for the LI GPS signal. 

At step 104, microprocessor 34 activates switch 18; turns on power to A/D 
converters 46 and digital snapshot memory 48; and a snapshot of data of duration 
K PN frames of the CVA code, where K is typically 100 to 1000 (corresponding to 
100 msec to 1 second dme duration) is collected. When a sufficient anrK>unt of 
data has been collected, microprocessor 34 turns off the A/D cwivencrs 46. 

The pseudorange of each satellite is computed in turn as follows. First, at 
step 106 for the given GPS satellite signal to be processed, the corresponding 
pseudorandom code (PN) is retrieved firom EPROM 54. As discussed shortly, the 
preferred PN storage formal is actually the Fourier transform of this PN code, 
sampled at a rate of 2048 samples per the 1023 PN bits. 

The data in digital snapshot memory 48 is processed in blocks of N 
consecutive PN frames, that is blocks of 2048N complex samples (N is an integer 
typically in the range S to 10). Similar operations are performed on each block as 
shown in the bottom loop (steps 108-124) of Figure 4. That is, this loop is 
pcrfontied a total of K/N times for each GPS signal to be processed. 

At step 1 08 the 2048N data words of the block are niultiplied by a complex 
exponential that removes the effects of Doppler on the signal carrier, as well as the 
effects of drifting of the receiver local oscillator. To illustrate, suppose the 
Doppler frequency obtained from conventional GPS receiver 12 (i.e., RAM 32) or 
the basestation SO plus local oscillator offsets corresponded to fe Hz. Then the 
premultiplication of the data wouU take the form of the function cP^^^"^^ n= (0, 

1, 2 2048N -1] + (B-1) X 2048N, where T=l/2.048 MHz is die sampling 

period, and the block number B ranges from 1 to K/N. 

Next, at step 1 10, the adjacent groups of N (typically 10) fnunes of data 
within the block are coherendy added to one another. That is, isamples 0, 2048, 
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4096, ... 2048(N-1) -1 arc added together, then 1. 2049, 4097. ... 2048(N-1) arc 
added together, etc. At this point the block contains only 2048 complex samples. 
An example of the waveform produced by such a summing c^)cration is illustrated 
in Figure 5B for the case of 4 PN frames. This summing operation may be 
considered a preprocessing operation which precedes the fast convolution 
operations. 

. Next, at steps 112-11 8. each of the averaged frames undergoes a matched 
filtering operadon, which purpose is to determine the relative timing between the 
received PN code contained within the block of data and a locally generated PN 
reference signal. Simultaneously, the effects of Doppler on the sampling dmes is 
also compensated for. These operations are greatly speeded, in one embodiment, 
by the use of fast convolution opcradons such as Fast Fourier Transform (EFT) 
algorithms used in a manner to perform circular convolution, as presendy 
described. 

In order to simplify discussion, the above mentioned Doppler 
ompensauon is initially neglected. 

The basic operation to be perfomied is a comparison of the data in the 
block being processed (2048 complex samples) to a similar reference PN block 
stored locally. The comparison is actuaUy done by (complex) multiplying each 
element of the data block by the corresponding element of the reference and 
summing the results. This comparison is termed a "correlation." However, an 
individual correlation is only done for one particular starting time of the data block, 
whereas there are 2048 possible positions tiiat might provide a better match. The 
set of all correlation operations for all possible starting positions is termed a 
"noatched ffltcring" operation. The full matched filtering operation is required in a 
preferred embodiment. 

The other times of the PN block can be tested by circulariy shifting the PN 
reference and reperfOTming the same operation. That is, if the PN code is denoted 
p(0) p(l) ... p(2047), tfien a circular shift by one sample is p(l) p(2) .... p{2047) 
p(0). This modified sequence tests to determine if the data block contains a PN 
signal beginning with sample p(l). Similariy the data block may begin with 
samples p(2), p(3), etc., and each may be tested by circulariy shifting the reference 
PN and reperforming the tests. It should be apparent that a complete set of tests 
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would require 204S x 2048 = 4,194,304 operations, each requiring a complex 
multiplication and addition. 

A more efficient, mathcmadcally equivalent n>ethod may be employed, 
udlizing the Fast Fourier Transfonn (FFT), which only requires approximately 12 
X 2048 complex muldplications and twice the number of additions. In this 
method, the FFT is taken for the data block, at step 1 12, and for the PN block. 
The FFT of the data block is multiplied by the complex conjugate of the FFT of the 
reference, at step 114, and the results are inverse Fourier transformed at step 118. 
The resulting data so gotten is of length 2048 and contains the set of correlations 
of the data block and the PN block for all possible positions. Each forward or 
inverse FFT operation requires P/2 log2 P operations, where P is the size of the 
data being transformed (assuming a radix-2 FFT algorithm is employed). For the 
case of interest, P=204g, so that each FFT requires 1 1 x 1024 complex 
multiplications. However, if the FFT of die PN sequence is prcstored in EPROM 
54, as in a preferred embodiment, dien its FFT need not be computed during the 
filtering prccess. The total number of complex multiplies for the forward FFT. 
inverse FFT and die product of die FFTs is xhixs (2 x 1 1 + 2) x 1024 = 24576, 
which is a savings of a factor of 171 over direct correlation. Figure 4C illustrates 
the waveform produced by this matched filtering operation. 

The preferred method of the current invention utilizes a sample rate such 
that 2048 samples of data were taken over die PN period of 1023 chips. This 
allows die use of FFT algoridims of length 2048. It is known diat FFT algoriduns 
that are a power of 2, or 4, are normally much more efficient than those of other 
sizes (and 2048 = 2ii). Hence the sampling rate so chosen significandy improves 
the processing speed. It is preferable that the number of samples of die FFT equal 
the number of san^)Ies for one PN frame so that proper circular convolution may 
be achieved. That is, diis condition allows the test of the data block against ail 
circularly shifted versions of die PN code, as discussed above. A set of alternative 
methods, known in the an as "overlap save" or "overiap add" convolution may be 
utilized if the FFT size is chosen to span a number of samples different from that 
of one PN frame length. These approaches require approximately twice the 
number of computations as described above for the preferred implementation. 

It should be ^parent to one skilled in die art how die above process may 
be modified by utilizing a variety of FFT algoridims of varying sizes together with 
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a variety of sample rates to provide fast convolution operations. In addition, a set 
of fast convolution aig(»ithms exist which also have the property that the number 
of computadons required are proportional to P log2P rather than P2 as is required 
in straightfcTward correladon. Many of diese algorithms are enumerated in 
standard references, for example, HJ. Nussbaumcr, "Fast Fourier Transform and 
Convolution Algorithms," New York, Springer- Vcrlag, C1982, In^wrtant 
examples of such algorithms are the Agarwal-Coolcy algorithm, the split nesting 
algorithm, recursive polynomial nesting algorithm, and the Winograd-Fouricr 
algorithm, ±c first three of which are used to perform convolution and the latter 
used to perform a Fourier transform. These algorithms may be employed in 
substitution of the preferred method presented above. 

The method of rime Doppler compensation employed at step 1 16 is now 
explained. In the preferred in^lementation, the sample rate utilized may not 
correspond exactiy to 2048 samples per FN frame due to Doppler effects on the 
received GPS signal as well as local oscillator instabilities. For example, it is 
known that the Doppler shift can contribute a delay error of ±2700 nsec/sec. In 
order to compensate for this effect, die blocks of data processed in the above 
description need to be time shifted to compensate for this error. As an example, if 
the block size processed corresponds to 5 PN frames (5 msec), then die time shift 
from one block to another could-be as much as ±13.5 nsec. Smaller time shifts 
result from local oscillator instability. These shifts may be con^icnsatcd for by 
time shifting the successive blocks of data by multiples of the time shift required 
by a single block. That is, if the DopplCT time shift per block is d, then the blocks 
are time shifted by nd, where n=4, 1, 2, .... 

In general these time shifts are fractions of a sample. Pcrfcmning these 
operations directly using digital signal processing methods involves the use of 
nonintegral signal interpolation methods and results in a high computation burden. 
An alternative approach, that is a prefcned method of the present invention, is to 
incorporate the processing within the fast Fourier transform functions. It is well- 
known that a time shift of d seconds is equivalent to multiplying the Fourier 
Transform of a function by eri^^, where f is the frequency variable. Thus, the 
time shift, may be accomplished by multiplying die FFT of the data block by 

e-j2iindn'f for n=0. 1. 2, 1023 and by c'i^i^'^^y^t for n=1024, 1025 

2047, where Tf is the PN frame duration (1 millisecond). This compensation adds 
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only about 8% to the processing time associated with the FFT processing. The 
compensation is broken into two halves in order to guarantee continuity of phase 
compensation across 0 Hz. 

After the matched filtering operation is complete, the magnitudes, or 
magnitudes-squared, of the complex numbers of the block are computed at step 
120. Either choice will work nearly as well. This operadon removes effects of 50 
Hz data phase reversals (as shown in Figure 5D) and low frequency carrier errors 
that remain. The block of 2048 samples is then added to the sum of the previous 
blocks processed at step 122. Step 122 may be considered a post processing 
operadon which follows the fast convolution operadon provided by steps 122- 
188. This continues undl all K/N blocks are processed, as shown by the decision 
block at step 124, at which time there remains one block of 2048 samples, from 
which a pseudorange is calculated Figure 5E illustrates the resulting waveform 
after the summing operadon. 

Pseudorange determitiadon occurs at step 126. A peak is searched for 
above a locally computed noise level. If such a peak is found, its dme of 
occurrence relative to the beginning of the block represents the pseudorange 
associated with the particular PN code and the associated GPS satellite. 

An interpoladon routine is utilized at step 126 to find the location of the 
peak to an accuracy much greater than that associated with the sample rate (2.048 
MHz). The interpolation routine depends upon the prior bandpass filtering used in 
the RF/IF portion of die GPS receiver 10. A good quality filter will result in a 
peak having a nearly triangular shape with the width of the base equal to 4 
samples. Under this condition, following subtraction of an average amplitude (to 
remove a DC baseline), the largest two amplitudes may be used to determine the 
peak position more precisely. Suppose these amplitudes are denoted Ap and Ap^i, 
where Ap^i^i, without loss of generality, and p is the index of the peak 
amplimde. Then the position of the peak relative to that conesponding to Ap may 
be provided by the formula: peak location = p+ Ap^(Ap+Ap^.i). For example if Ap 
= Ap4.i, then the peak location is found to be p+ 0.5, that is, halfway between the 
indices of the two samples. In some situations die bandpass filtering may round 
the peak and a three point polynomial interpolation may be itx>re suitable. 
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In the preceding processings a local noise reference used in thresholding 
may be computed by averaging all the data in the final averaged block, after 
removing the several largest such peaks. 

Once the pseudorange is found* the processing continues at step 128 in a 
similar manner for the next satellite in view, unless all such satellites have been 
processed. Upon complenon of the processing for all such satellites, the process 
continues at step 130 where the pseudorange data is transmitted to the basestadon 
50 over communication link 42, where the final posidon calculation of the retnote 
is performed (assuming Method 3 is utilized). Alternatively, the position 
calculation may be peifOTmed at GPS receiver 10 using satellite ephemeris data 
collected by conventional GPS receiver 12 and stored in RAM 32. The computed 
position may be displayed on display 36 and/or transmitted to basestadon 50 over 
communication link 42. Finally, at step 132, the majority of the snapshot GPS 
receiver circuitry of the GPS receiver 10 is placed in a low power state, awaiting a 
new command to perform another positioning operation. 

GPS receiver 10 can continue to operate in the snapshot mode, computing 
pseudoranges and/or positions periodically, until GPS receiver 10 is positioned 
such that antenna 16 again has a clear view of the sky, at which time conventional 
GPS receiver 12 can again be used to acquire and track GPS satellites in order to 
obtain a position fix. In the foregoing embodiment, the processing of GPS signals 
tern each satellite while in the snapshot mode occurs sequentially in time, rather 
than in parallel. In an alternative embodiment, the GPS signals from all in-vicw 
satellites may be processed together in a parallel fashion in time. 

Aldiough the methods and spparatus of die present invention have been 
described with reference to GPS satellites, it will be appreciated that the teachings 
are equally applicable to positioning systems which utilize pseudolites or a 
combination of satellites and pseudolites. Pseudolites are ground based 
transmitters which broadcast a PRN code (similar to a GPS signal) modulated on 
an L-band carrier signal, generally synchronized with GPS time. Each transmitter 
may be assigned a unique PRN code so as to permit identification by a rcnnote 
receiver. Pseudolites are useful in situations where GPS signals from an orbiting 
satellite might be unavailable, such as tunnels, mines, buildings or other enclosed 
areas. The term "satellite", as used herein, is intended to include pseudoliic or 
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equivalents of pseudolites, and the tcnn GPS signals, as used herein, is intended 
to include GPS-like signals from pseudolites or equivalents of pseudolites. 

It will be further appreciated that the methods and apparatus of the present 
invention are equally applicable for use with the GLONASS and other satellite- 
based positioning systems. The GLONASS system differs from the GPS system 
in that the emissions from different satellites are differentiated from one another by 
udUzing slightly different carrier frequencies, rather than utilizing different 
pseudorandom codes. In this situadon, substantially all the circuitry and 
algorithms described above are applicable, with the exception that when 
processing a new satellite's emission, a different complex exponential multiplier is 
used to preprocess the data. The operation may be combined with the Doppler 
correction operation of step 108 of Figure 4, without requiring any additional 
processing operations. Only one PN code is required in this situadon, thus 
eliminating step 106. 

In the foregoing specification, the invention has been described with 
reference to specific exemplary embodiments thereof. It will, however, be evident 
that various modifications and changes may be cnade thereto without departing 
from the broader spirit and scope of the invention as set forth in the appended 
claims. The specification and drawings are, accordingly, to be regarded in an 
illustrative rather than a restrictive sense. 
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CLAIMS 

What is claimed is: 

1 . A global positioning system (GPS) receiver, comprising: 
first circuitry for receiving and processing pseudorandom 

sequences transmined by a plurality of orbiting satellites, said first circuitry 
configured to perform correlation operations on said pseudorandom sequences to 
determine pseudorangcs from said GPS receiver to said satellites; and 

second circuitry coupled to said first circuitry, said second circuitry 
configured for receiving and processing said pseudorandom sequences when said 
GPS receiver experiences blockage conditions, said second circuitry configured to 
perform said processing, by digitizing and storing GPS data comprising a 
predetermined record length of said pseudorandom sequences and by performing 
fast convolution operations on said stored GPS data to determine said 
pseudorangcs. 

2. A global positioning system (GPS) receiver as in claim 1 wherein 
said first circuitry and said second circuitry comprise a single integrated circuit 

3 . A global positioning system (GPS) receiver as in claim 1 wherein 
said second circuitry comprises: 

a memory configured to receive and store said GPS data; and 
a programmable digital signal processor (DSP) coupled to said 

memory, said programmable DSP configured to perform fast convolution 

operations on said GPS data. 

4^ A global positioning system (GPS) receiver, comprising: 

an antenna for receiving GPS signals at an RF frequency from in 

view satellites; 

. a downconvcrter coupled to said antenna, said downconverter for 
reducing the RF frequency of said received GPS signals to an intermediate 
frequency (IF); 

a conventional GPS receiver adaptable to be coupled to said 
downconvcner, said conventional GPS receiver for acquiring and tracking a 
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plurality of GPS satellite signals and for extracting Doppler information from said 
GPS satellite signals; and 

first circuitry coupled to said conventional GPS receiver and 
adaptable to be coupled to said downconverted, said first circuitry configured for 
receiving and processing said received GPS signals when said GPS receiver 
experiences blockage conditions, said first circuitry configured to perform said 
processing by digitizing and storing GPS data comprising a predetermined record 
length of said IF GPS signals and by performing fast convolution operations on 
said stored GPS data to determine said pseudoranges. 

5 . A GPS receiver as in claim 4 wherein said first cinniicry comprises: 
a digitizer adaptable to be coupled to said downconverter upon 

receipt of a signal indicating that said conventional GPS receiver is experiencing 
blockage conditions, said digitizer for sampling said IF GPS signals at a 
predetermined rate to produce sampled IF GPS signals; 

a memory coupled to said digitizer, said memory for storing the 
sampled IF GPS signals; 

a digital signal processor (DSP) coupled to said memory, said DSP 
for performing fast convolution operations on said sampled IF GPS signals. 

6 . A GPS receiver as in claim S further comprising a local oscillator 
coupled to said downconverter, said local oscillator providing a first reference 
signal. 

7 . A GPS receiver as in claim 5 wherein said DSP compensates said 
sampled IF GPS signals using said Doppler information and wherein said fast 
convolution operations provide a pseudorange informatioa 

8 . A GPS receiver as in claim 5 wherein said first circuitry further 
comprises a power management circuit coupled to said digitizer, wherein after said 
IF GPS signals are stored in said memory, said power management circuit powers 
down said digitizer. 

9 . A GPS receiver as in claim 5 wherein said GPS signals originate 
from pseudolites. 
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10. A GPS receiver as in claim 5 further comprising a receiver coupled 
to said first circuitry, said receiver for receiving differential GPS correction signals 
from a basestation. 

11. A method for using a dual mode GPS receiver, said method 
comprising the steps of: 

activating said GPS receiver in a first mode of operation including, 
receiving GPS signals from in view satellites; 
downconverting and demodulating said GPS signals to 
extract Doppler information regarding in view satellites 
and to compute pseudorange information; 
storing said Doppler information; 
detecting when said GPS receiver is experiencing blockage 
conditions and activating a second mode of operation in response 
thereto, the second mode including. 

digitizing said GPS signals at a predetermined rate to 

produce sampled GPS signals; 
storing said sampled GPS signals in a memory; and 
processing said sampled GPS signals to derive 

pseudoranges by performing fast convolution operations 
on said sampled GPS signals. 

12. A method as in claim 1 1 wherein said Doppler information is used 
during said second mode of operation to compensate said sampled GPS signal. 

13. A method as in claim 12 wherein during said first mode of 

, operation, satellite ephemeris information is extracted from said GPS signals and 
stored in a memory and wherein during said second mode of operation said 
satellite ephemeris information is applied to said pseudoranges to calculate a 
position of said GPS receiver. 

14. A method as in claim 13 wherein said position is displayed to a 
user of said GPS receiver. 

15. A method as in claim 13 wherein said positioii is transmitted from 
said GPS receiver to a basestation. 
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16. A method as in claim 1 1 wherein said GPS signals originate from 
pseudolites. 

17. A method as in claim 1 1 further comprising the steps of: 
receiving differential GPS conecdon signals at said GPS receiver 

before said step of processing; and 

using said differential GPS signals during said step of processing 
to compute said position. 

18. A tracking process utilizing global positioning system (GPS) 
satellites for determining the position of a remote sensor, the process comprising 
the steps of: 

receiving GPS signals at said remote sensor from a plurality of in 
view GPS satellites; 

computing first pseudoranges utilizing said GPS signals and a 
conventional GPS receiver; 

utilizing said first pseudoranges and satellite cphcmeris data to 
compute a geographic location for said sensor, 

detecting when said remote sensor is experiencing blockage 

conditions; 

computing second pseudoranges utilizing digitized and buffered 
segments of said GPS signals, said computing comprising digital signal 
processing using fast convolution operations; and 

utilizing said second pseudoranges and said satellite ephemeris data 
to compute said geographic location. 

19. The tracking process of claim 1 8 wherein the step of computing 
second pseudoranges further comprises: 

storing said received GPS signals in a memory as stored data; 

processing said stored GPS signals for one or more of said in view 
GPS satellites in a digital signal processor by, 

breaking said stored data into a series of contiguous blocks whose 
durations are equal to a multiple of the frame period of the pseudorandom (PN) 
codes contained within the GPS signals; 
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rcmoving, for each block, the effects of Doppler carrier and 
receiver local oscillator fircqucncy uncertainty; 

creating, for each block, a compressed block of data with length 
equal to the duration of a pseudorandoai code period by coherently adding together 
successive subblocks of data, said subblocks having duration equal to one PN 
ftame; 

performing, for each compressed block, a matched filtering 
operadon to deteraiine the rcladvc timing between the received PN code contained 
within the block of data and a locally generated PN reference signal, said matched 
filtering operation utilizing said fast convolution techniques; 

determining said pseudorange by peTfom:iing a magnitude-squared 
operation on the products created from said matched filtering operation and 
combining said magnitude-squared data for all blocks into a single block of data by 
adding together said blocks of magnitude-squared data to produce a peak, the 
location of said peak being determined using digital interpolation methods and 
corresponding to said pseudorange. 

20. The tracking process of claim 19 wherein said matched filtering 
operation conoprises: 

performing a convolution of the compressed block's data against a 
stored rcplkra of the pseudorandom sequence (PRS) of die GPS satellite being 
processed, said convolution being performed using said fast convolution 
algorithms to produce a product of the convolution. 

21 . The tracking process of claim 19 wherein the fast convolution 
algorithm used in processing the buffered GPS signals is a Fast Fourier Transform 
(FFT) and the result of the convolution is produced by computing the forward 
transform of said compressed block by a prestored representation of the forward 
transform of die pseudorandom sequence (PRS) of the GPS satellite being 
processed to produce a first result and then performing an inverse transformation 
of said first result to recover said result. 

22. The tracking process of claim 1 8 wherein a basestation computes 
the geographic location of said sensor. 
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23. A computer readable medium containing a computer program 
having executable code for a global positioning system (GPS) receiver, said 
computer program comprising: 

first instructions for receiving GPS signals from in view satellites, 
said GPS signals comprising pseudorandom (PN) codes; 

second instructions for computing pseudoranges from said received 
GPS signals using a convendonal GPS receiver, 

third instrucdons for detecting when said GPS receiver is 
experiencing blockage condidons and digitizing said GPS signals at a 
predetermined rate to produce sampled GPS signals in response thereto; 

fourth instrucdons for storing said sampled GPS signals in a 

memory; and 

fifth instrucdons for processing said sampled GPS signals by 
performing fast convolution operations on said sampled GPS signals, said fifth 
instrucdons comprising a matched filtering operation to determine the relative 
timing between said PN codes and locally generated PN reference signals. 

24. A global positioning system (GPS) receiver apparatus, comprising: 
a first GPS receiver adaptable to be coupled to a source of GPS 

satellite signals, said fint GPS receiver for acquiring and tracking a plurality of 
GPS satellite signals and for extracting I>oppIer information from said GPS 
satellite sigiuds; and 

a second GPS receiver adaptable to be coupled to said source of 
GPS satellite signals during blockage conditions, said second GPS receiver 
configured to sample and store said GPS signals at a predetermined rate to produce 
sampled GPS signals and to process said.samplcd GPS signals using fast 
convolution operations, said second GPS receiver further conRgured to respond to 
a signal indicating that said GPS receiver apparatus is experiencing blockage 
conditions and to initiate a snapshot GPS mode wherein said second GPS receiver 
is coupled to said source of said GPS satellite signals. 

25 . A GPS receiver as in claim 24 wherein said first GPS receiver and 
said second GPS receiver are formed on a single integrated circuit 
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26. A GPS receiver as in claim 24 wherein said signal indicating that 
said GPS receiver is experiencing blockage conditions is generated by said first 
GPS receiver. 

27. A GPS receiver as in claim 24 wherein said GPS signals originate 
from pseudoiites. 

28 . A GPS receiver as in claim 24 further comprising a communicaaon 
receiver coupled to said first GPS receiver and to said second GPS receiver, said 
communicaiion receiver for receiving differential GPS correction signals. 
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